再現コードも書けなかったし、良く分からないのでメモのみ。
症状 §
Windows Store Appのプロジェクト内のファイルを、非同期で開こうとするとハングする。(プロセスが先に進まなくなる)
ただしファイルは存在し、他の方法で開くことができることを確認済み。
詳細 §
継承したクラスのコンストラクタ内から、async/awaitを使ったメソッドを呼び出していた。その呼び出しそのものはWaitメソッドで明示的に待っていた。
ハングしていたのはそこではなくawaitを付けたメソッドだった。(場所は一定しなかった)
原因 §
不明。ただし、async/awaitの仕様をやめ、明示的にWaitメソッドで待つように記述したら動作した。async/awaitに問題があるようだが、詳細は未調査。
対策 §
async/awaitの利用をやめ、明示的に戻って来たTaskオブジェクトのWaitメソッドで待つコードを書く。
感想 §
これで、ほぼ丸1日潰れた!
なのに、短い再現プログラムが書けなかった!
何か他にも再現条件があるようです。